MySQL架构

221次阅读
没有评论

共计 2265 个字符,预计需要花费 6 分钟才能阅读完成。

两台或以上数据库实例,通过二进制日志,实现数据的“同步 ” 关系。

主从复制

实例准备:两台以上 MySQL 实例,server_id 不同。

主库

  • 主库开启二进制日志
  • 主库建立复制用户:grant replication slave on . to repl@’10.0.0.%’ identified by ‘123’;
  • 主库备份:mysqldump -A –master-data=2 –single-transaction -R -E –triggers >/tmp/full.sql
  • 告知从库复制信息,找到复制开始起点:grep "\-- CHANGE MASTER TO" /tmp/full.sql

从库

  • 恢复到从库:mysql </tmp/full.sql
  • 从帮助中获取 change master to 语句进行修改:mysql> help change master to
  • 执行 CHANGE MASTER TO 命令
  • 从库开启专用复制线程:start slave;
  • 验证主从状态:show slave status \G

主从复制原理

文件

主库:binlog 文件

从库:

  • relay-log 文件:存储接收的 binlog,默认存储在从库数据目录下,手工定义:relay_log_basename=/data/3307/data/relay-bin
  • master.info:连接主库信息,已经接收 binlog 位置点信息。默认存储在从库数据目录下,也可将配置信息写入到表中:master_info_repository = TABLE
  • relay-log.info:记录⽂件复制进度,下⼀个事件从什么位置开始。默认存储在从库数据目录下,也可以手工定义:relay_log_info_repository = TABLE

线程

主库:Binlog_dump_Thread,作用是用来接收从库请求,并将 binlog 投递给从库。显示正在运行线程:show processlist;

从库:

  • IO 线程:请求 binlog,接收 binlog
  • SQL 线程:回放 relay 日志

原理

  1. S:change master to 信息写入到 master.info,执行 start slave; 启动 IO 线程和 SQL 线程
  2. S:IO 线程读取 master.info 信息,获取主库信息连接主库
  3. M:分配 DUMP 线程,专门和 IO 线程通信
  4. S:IO 线程根据 master.info 记录的 binlog 文件名和 position 号,请求主库新日志
  5. M:DUMP 线程接收请求,截取日志,返回给 IO 线程
  6. S:IO 线程将收到日志存储到 TCP/IP 缓存,立即返回 ACK 给主库,主库工作完成
  7. S:IO 线程将缓存数据,存储到 relay-log 日志文件,并更新 master.info,IO 线程工作结束
  8. S:SQL 线程读取 relay-log.info,获取上次执行到的位置点
  9. S:SQL 线程向后执行新的 relay-log,再次更新 relay-log.info

小细节:
S:参数 relay_log_purge=ON,会定期删除用用过的 relay-log
M:DUMP 线程会实时监控主库 binlog 变化,如果有新变化,发信号给从库,IO 线程再请求

主从监控

主库方面:

  • show processlist;
  • show slave hosts;

从库方面:

  • show slave status \G

MHA

全称:Master High Availability,是 Perl 语言写的 MySQL 故障切换方案,故障切换时间 10-30s。

MHA 由 node 和 manager 组成;

  • node:所有数据库机器都要部署,master 是一个 node,slave 也是一个 node
  • manager:相当于 server,会对 node 进行管理,配置检查,binlog 和 relay-log 获取,执行切换任务等。可以单独部署在 server 上(tj),单独部署可以管理多套主从架构。也可以部署在某个 slave 上,如果部署在 slave 上,那么该 slave 就无法被升级为主库

部署 MHA 高可用框架

配置关键程序软连接:

ln -s /app/database/mysql/bin/mysqlbinlog /usr/bin/mysqlbinlog
ln -s /app/database/mysql/bin/mysql /usr/bin/mysql

配置各节点互信:

rm -rf /root/.ssh
ssh-keygen
cd /root/.ssh
mv id_rsa.pub authorized_keys
scp -r /root/.ssh 10.0.0.52:/root 
scp -r /root/.ssh 10.0.0.53:/root

各节点安装 Node:

yum install perl-DBD-MySQL -y
rpm -ivh mha4mysql-node-0.58-0.el7.centos.noarch.rpm

安装 Manager:

yum install -y perl-Config-Tiny epel-release perl-Log-Dispatch perl-Parallel-ForkManager perl-Time-HiRes
rpm -ivh mha4mysql-manager-0.58-0.el7.centos.noarch.rpm

创建 MHA 专用监控管理用户:grant all privileges on . to mha@’10.0.0.%’ identified by ‘mha’;

Atlas

Atlas 中间件是由奇虎 360 基于 MySQL 官方中间件 mysql-proxy 二次开发实现,能够对数据库进行读写分离、分库分表配置,配合 MHA 架构进行高可用环境搭建有较好效果。

MyCAT

分布式架构

正文完
 0
阿伯手记
版权声明:本站原创文章,由 阿伯手记 于2024-02-22发表,共计2265字。
转载说明:本站原创内容,除特殊说明外,均基于 CC BY-NC-SA 4.0 协议发布,转载须注明出处与链接。
评论(没有评论)
验证码

阿伯手记

阿伯手记
阿伯手记
喜欢编程,头发渐稀;成长路上,宝藏满地
文章数
766
评论数
204
阅读量
449370
今日一言
-「
热门文章
职场救急!AI请假话术生成器:1秒定制高通过率理由

职场救急!AI请假话术生成器:1秒定制高通过率理由

超级借口 不好开口?借口交给我!智能生成工作请假、上学请假、饭局爽约、约会拒绝、邀约推辞、万能借口等各种借口理...
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
巴别英语:用美剧和TED演讲轻松提升英语听力与口语

巴别英语:用美剧和TED演讲轻松提升英语听力与口语

还在为枯燥的英语学习而烦恼吗?巴别英语通过创新的美剧学习模式,让英语学习变得生动有趣。平台提供海量美剧和 TE...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
TVAPP:开源电视盒子资源库,一键打造家庭影院

TVAPP:开源电视盒子资源库,一键打造家庭影院

导语 TVAPP 是一个专为 Android TV 电视盒子用户打造的开源影音资源库,集成了影视、直播、游戏等...
2025年12月 每日精选

2025年12月 每日精选

关于每日精选栏目 发现一些不错的资源,点击 这里 快速投稿。 12 月 26 日 .ax 顶级域 目前全球唯一...
最新评论
15220202929 15220202929 怎么用
八对 八对 麻烦大佬更新下【堆新】的友链站名:八对星星描述:极目星视穹苍无界•足履行者大地有疆链接:https://8dui.com图标:https://cf.8dui.com/logo.webp横标:https://cf.8dui.com/logo-w.webp订阅:https://8dui.com/rss.xml
三毛笔记 三毛笔记 已添加
DUINEW DUINEW 已添加贵站,期待贵站友链~博客名称:堆新博客地址:https://duinew.com/博客描述:堆新堆新,引力向新!——堆新(DUINEW)博客头像:https://d.duinew.com/logo.webp横版头像:https://d.duinew.com/logo-w.webp博客订阅:https://duinew.com/rss.xml
hedp hedp 没看懂
bingo bingo 直接生成就可以啦,也可以添加一些选项
满心 满心 申请更新下友联信息,原名:满心记,现名:周天记原域名:qq.mba,现域名:zhoutian.com描述:我在人间混日子
开业吉日 开业吉日 没看明白这个怎么用
开业吉日 开业吉日 beddystories 这个网站太赞了,收藏
热评文章
夸克网盘快传助手提高非VIP下载速度

夸克网盘快传助手提高非VIP下载速度

夸克网盘限速这个大家都知道,不开会员差不多限速在几百 K。那有没有办法在合法合规途径加速下载夸克网盘呢?这里推...
清华大学官方免费DeepSeek教程

清华大学官方免费DeepSeek教程

AI 领域近期最引人注目的焦点当属 DeepSeek,这款由中国创新企业深度求索研发的人工智能工具,正以开放源...
Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 免费开源短网址程序,基于Fastify、Vercel和Supabase构建

Short-Link 是一款基于 Fastify、Vercel 和 Supabase 构建的 URL 缩短服务...
国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

国内已部署DeepSeek模型第三方列表 免费满血版联网搜索

本文收集了目前国内已部署 DeepSeek 模型的第三方列表,个个都是免费不限次数的满血版 DeepSeek,...
Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 在线中文姓名生成器

Chinese Name Generator 是一款在线中文姓名生成器,可在几秒内生成符合个人需求的中文名字。...
BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 完全免费儿童睡前故事库,让孩子随时随地入睡更轻松

BeddyStories 是一个致力于为儿童提供优质睡前故事的在线平台,用户可以在这里找到来自世界各地的经典故...
DrawLink:一键生成链接视觉卡片,提升分享点击率

DrawLink:一键生成链接视觉卡片,提升分享点击率

小贴士 :此站或已变迁,但探索不止步。我们已为您备好「类似网站」精选合集,相信其中的发现同样能为您带来惊喜。